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PROVISIONAL SPECIFICATION FOR AN INVENTION ENTITLED:- 

"DATA COLLECTION SYSTEM USING REMOTELY CONFIGURABLE 

SCRIPTING" 

This invention is described in die following statement:- 




TECHNICAL FIELD 

This invention relates to a digital data collection system that provides the ability to 
configure, re-configure and append software and functionality to remote computer 
installations regardless of the location or Windows ™ operating system of the remote 
5 computer installation. 
BACKGROUND 

Issues and questions surrounding the problem of remote data collection include: 

• How will specific data be retrieved? 

• When is data to be retrieved? 
10 • How is data to be sent? 

• When is data to be sent? 

• How can the collection system be modified remotely? 

• How are the solutions to these issues going to be controlled? 

• How can the collection system functions be customized? 

15 • How can new functions (i.e. Dynamic Link Libraries) be added? 

• How can old functions be replaced? 

• How can new data sources be added? 

Any solution to the above problems and issues should preferably not significantly 
20 impact on the operation of the remote machine from which the data is requested. 

Current systems address some of the abovementioned needs and issues associated 
with remote data collection. A common approach is to write a single software 
application that is: 
25 • Hard-coded to connect to a specific data source 

• Hard-coded to connect to a temporary database 

• Hard-coded to transmit data 

Such an approach is typically taken because software is not available that is 
30 compatible with all the different remote systems. Different Operating S ystems, 
different databases and different communication protocols make every solution 
unique 
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Subsequently, should any of the coded or information embedded in the hard-coded 
program need to be changed after installation, a rewrite and complete re-compilation 
of the program and an on-site installation is typically required. Changes arise for 
many reasons but they could be as simple as a change in a directory or as problematic 
5 as a change in the database. 

The following universal needs are indicative of the shortcomings identified by current 
data collection systems: 

• Retrieval of data from multiple remote locations 

10 • To configure, re-configure and append installations remotely 

• Non-reliance upon and independence from a particular database technology or 
data source type used at the remote location 

It is an aim of this invention to provide a data collection system that reduces or 
15 eliminates some if not all of the shortcomings of the prior art or at least provides an 
alternative approach. 

Brief Description of the Invention 

In a broad aspect of the invention a data collection system consists of one or more 
objects; 

20 a central object; and 

one or more other objects; wherein 
all objects have a common interface and functional elements that reference one or 
more common function libraries, such that a central object and at least one other 
object is installed at a remote data source to communicate data from said source to a 

25 remote data collection object. 

In a further aspect of the invention extended Markup Language is the language used 
between objects. 



30 In an aspect of the invention communication between objects can be synchronous or 
asynchronous. 
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Iii yet a further aspect of the invention said central object comprises a core system 
having form and central objects and at least one configuration file. 



In a further aspect of the invention a base system comprises a core system as well as a 
5 transmit object, an installer object and a timer object. 

In a further aspect of the invention a functional system comprises a core system as 
well as a store object and a connector object. 

10 Specific embodiments of the invention will now be described in some further detail 
with reference to and as illustrated in the accompanying figures. These embodiments 
are illustrative, and not meant to be restrictive of the scope of the invention. 
Suggestions and descriptions of other embodiments may be included but they may not 
be illustrated in the accompanying figures or alternatively features of the invention 

15 may be shown in the figures but not described in the specification. 

Brief Description of the Figures 
Fig.l depicts a Data Collector System Object; 
Fig. 2 depicts Data Collector System Communication Environment; 
Fig. 3 depicts synchronous communication between the Objects; 
20 Fig. 4 depicts asynchronous communication between the Objects; 
Fig. 5 depicts the Data Collector core system; 
Fig. 6 depicts the process of command execution 

Fig. 7 depicts an example of the Central Core System Object (Glue) executing and 
passing commands at startup; 
25 Fig. 8 depicts a Base system; 

Fig, 9 depicts the process of establishing a heartbeat; 

Fig, 10 depicts the installation of a new object by the Installer object; 

Fig. 11 depicts the complete functional system; 

Fig. 12 depicts the retrieval of data from the remote data source and storage of this 
30 data into the local database; 

Fig. 13 depicts the sending of data bundles at set time intervals; and 
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Fig. 14 depicts the sending of data bundles at set capacity levels. 

To better understand the invention, a preferred embodiment will now be described, 
but it will be realized that the invention is not to be confined or restricted to the 
5 precise nature of this embodiment. 

Detailed Description of an Embodiment of the Invention 

The Data Collector System of the invention consists of independent, yet related, 
objects which together through the control imparted by one central object collects, 
10 stores and transmits data. 

The central object communicates with, and co-ordinates'the activity of all other 
objects by sending and receiving XML (extended Markup Language) commands. The 
use of XML commands is preferable. The use of multiple objects, which together 
15 perform separate functions through a common interface, enables the removal and 
addition of functionality. The use of XML scripting together with the ability to add 
and remove functionality enables remote configuration of the Data CoDector System. 

The Data Collector System is comprised of a collection of Data Collector System 
20 Objects that include an XML Configuration File, the Common Function Library, and 
a Windows Application (which hosts the Collector Objects). 

Data Collector System Communication Interface 

Each Data Collector System Object within the Data Collector System is comprised of 
25 two distinct parts depicted in Fig. 1 . 

• Common Interface 

• Specialized Functionality 

The Common Function Library (CFL) is accessible to all Data Collector System 
Objects and contains standard routines. Both the Common Interface (CI) and 
30 Specialized Functionality (SF) address the CFL yet both access a distinctly separate 
set of sections of the library, that is they do not share functionality within the library. 
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The arrangement depicted is only preferable, as it would be quite acceptable to 
provide the CI and SF with separate CFLs. 

Common Interface 

The Common Interface defines a limited and fixed set of methods/properties that each 
Object knows about. These are: 

• SetUp • Error 

• ShutDown • isHealthy 

• CommandXML • pjng 

• ReturnCom mandXML 

The properties CommandXML and RetumCommandXML provide the functionality 
to pass XML commands between two Objects. Fig 1 illustrates how the Data 
Collector System Object is comprised of the Common Interface and Specialized 
Functionality parts, as well as the flow in and out of the XML commands. 

An XML-Command is a single XML document, which contains a top-level command 
and optionally a series of sub-commands. The top-level command with sub- 
commands form a to-do list The associated Object executes the top-level command 
first, then the first sub-command is promoted to be the top-level command and its 
associated Object executes it. Execution continues until all sub-commands are 
promoted and executed. 

On receipt of an XML command, the Common Interface using the Command XML 
property performs the following: 

1. Inspects the XML to retrieve the command and any associated parameters. 

2. Calls the relevant specialized functionality that implements the command 
(passing parameters if required) 

3. If the call returns any XML data, it adds this data to the current command. 

4. Returns the (possibly updated) command to whence it came, in general the 
Central Core System Object (Glue), via the RetumCommandXML property. 

5. Central Core System Object (Glue) promotes the first sub-command, if one 
exists, and if so repeats steps 1 to 5. 





Specialized Functionality 

The Specialized Functionality part of the component, under instruction from the 
Common Interface part, performs specific operations such as connecting to a database 
to retrieve values or to the Internet to send information. A component may have more 
5 than one specialized operation. 

COM* is used to implement the functionality of this part of the component, and as 
such, it is comprised of simple procedural calls, which may or may not return data. If 
it does return data, does so as valid XML. 

10 Data Collector System Communication Environment 

Any object that possesses a Common Interface may be added to the Data Collector 
System. 

The Data Collector System Communications Environment comprises one or more 
15 Data Collector System Objects and respective Common Function Libraries, plus a 
Configuration File and a Windows Executable. This is depicted in Fig. 2. 

Intra-system Communication Protocol 

Currently, Windows* COM+ technology is used to facilitate communication between 
Objects. Whilst it is necessary to communication between Objects, it is not necessary 
20 to use COM-k Other protocols, such as HTTP, MSMQ or SMTP, may be used. 

Synchronous vs. Asynchronous Communication 

Currently, communication between the Objects is synchronous, meaning that the 
Objects within the system may execute only one XML-Command (containing top- 
level & sub-commands) at any moment in time. New XML-Commands can only 
25 begin execution when all Objects become idle. 

Despite this current implementation, communication between Objects may be 
configured so that it is asynchronous. Therefore, whilst an Object cannot execute two 
commands simultaneously, the system as a whole will be able to execute commands 
30 asynchronously because distinct objects would be able to execute distinct commands 
simultaneously. Fig. 3 -Synchronous and Fig. 4 Asynchronous show this relationship. 
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The Data Collector System Objects accommodate either method. 



The Data Collector System preferably uses: 

• An XML scripting language to co-ordinate object activities. 

5 • A central object manages the activities of independent yet related objects. 

• The Data Collector System is remotely configurable once a base system is 
installed as will be illustrated later in this specification. 

As the arrangement of objects is completely configurable and re-configurable, the 
10 number and type of objects present within the Data Collector System at any one time 
can vary. 

Three distinct systems that make up the Data Collector System, each comprised of 
different object configurations are used: 
15 • Core system 

• Base system 

• Functional system 

Core system 

The core system is comprised of the essential objects necessary for the creation of all 
20 other objects. The core system alone creates the objects necessary to form the base 
system. 

Base system 

The base system supports, and is essential for, remote configuration such that an 
entire Data Collector System may be built and maintained remotely. 

25 Functional system 

The functional system addresses many of the issues concerning how the remote data is 
to be collected and when. 

The advantages of remote data retrieval include: 

30 

• Data from multiple remote sites can be brought together 
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• System is completely remotely configurable 

• Upgrades can be implemented "on the run" 

CORE SYSTEM 

The Data Collector System core system supports the following: 
5 • Creation of new objects to form the base system 

Objects 

The Core System of the Data Collector System, depicted in Figure 5, is comprised of 
the following objects: 

• Form 

10 • (Central Core System Object herein referred to as Glue) 

• Configuration File 

Form 

The Form object creates and holds Glue in memory. Form also contains a physical 
timer and sends regular time signals ("pings") to Glue. Once new objects are created, 
15 Glue in turn "pings" these objects. The ping is used for internal timings if required, 
however, is mostly ignored. The Timer object is the main object that utilizes the ping. 

Glue 

Glue binds the core system together and it in turn holds all objects of the Data 
Collector System in memory. It is responsible for creating all other objects of the Data 
20 Collector System and for controlling the activities of these objects through the use of 
XML commands. Glue executes commands addressed to it and passes commands 
addressed to other objects to those objects for execution. Once an object (including 
Glue) has executed a command, that command is passed back to Glue to indicate that 
execution is complete. 

25 Glue- Commands are placed in a queue 

When Glue receives a command to be executed by itself or by another object, it is 
placed at the end of a queue. The command at the head of the queue is called the 
current command and is the command currently being executed. Once execution of 
the current command is complete, Glue pops the next command off of the queue. This 
30 command becomes the current command. 
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Glue- Commands may contain sub-commands 

When the current command contains sub-commands, Glue directs the entire command 
including the sub-commands to the object to which the current command is addressed. 
This object then executes the current command and once completed sends the current 
5 command together with the subcommands back to Glue. 

When Glue receives an executed command back from an object, Glue checks to see if 
the command contains sub-commands. If the command does contain sub-commands, 
Glue promotes the first sub-command as the current command. The current command, 
10 together with any remaining sub-commands, is then sent to the relevant object for 
execution. These processes re-iterate until all sub-commands have been executed (see 
Fig 6). Figure 6 demonstrates the involvement of Glue in the process of command 
execution. 

Glue- Commands may generate other commands 

15 If the result of the execution of a command is additional commands needing to be 
executed, these additional commands are placed at the end of the queue within Glue, 
and are executed once the current and preceding commands have been executed. 

Glue- Commands may return data 

Commands passed back to Glue may be accompanied by data. Data returned may be 
20 referenced by associated sub-commands through use of the following tag: 

datatype= " <nameof datatype> 1 

Once the execution of a command and its sub-commands is complete, any data 
returned and held is discarded and can not be used by any other commands in the 
queue. 

25 Glue- CreateObject command 

Glue can execute a variety of commands, however, the most important command to 
be executed is the CreateObject command. The CreateObject command enables Glue 
to create all other independent, system-related objects. Once an object is created, Glue 
can send commands addressed to this object for execution. 
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Configuration File 

The configuration file stores all commands to be executed on startup and contains a 
list of all required initialization data. Glue reads the configuration file on startup. 

XML Events that occur in the Core System 

5 The main XML events that occur within the core system are: 

1. Form creates Glue 

2. Glue reads configuration file 

3. Glue executes and delegates commands within configuration file, an example 
of which is to create objects 

10 <docnd object^ *Glue u command** CreateObject ° createobject=*X* /> 

Creating an object 

The CreateObject command can only be executed by Glue and is used to create all 
other independent and related objects. The Configuration File contains many 
CreateObject commands as this is read by Glue on startup and is necessary for the 
15 construction of the base system (see Figure 7). Figure 7 demonstrates the type of 
events, which occur on startup of the Data Collector System. 

BASE SYSTEM 

The Data Collector System base system supports the following: 
1 . Transmission of XML data from and to the client-end 

20 2. Creation of new objects 

The Data Collector System base system, depicted in Figure 8, is comprised of the core 
system plus the following three additional objects: 

• Transmit 

• Installer 
25 • Timer 

Transmit Object 

The Transmit object sends and receives XML data to and from the DATA 
COLLECTOR SYSTEM server and as shown in Fig. 8 this is done via the Internet. 
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The Transmit object includes the following functions: 

1. Set up the URL addresses for the sending and receiving of data. 

2. Send data to the DATA COLLECTOR SYSTEM server using the Dock 
command. 

3. Notify the DATA COLLECTOR SYSTEM server that Collector is 'alive' 
using the Heartbeat command. 

4. Optionally encrypts and compresses data. 

On receipt of a heartbeat, the DATA COLLECTOR SYSTEM server sends bade a 
command informing the Collector to either do nothing or to perform some action. The 
DATA COLLECTOR SYSTEM server can only send commands if a heartbeat is 
received. 

Installer Object 

The Installer object takes a data message that contains an encoded file and recreates it 
If the file is of the type DLL (Dynamic Link Library) then the installer will register 
the library. This functionality enables new objects to be created and existing objects to 
be upgraded. 

Timer Object 

The Timer object is responsible for storing commands to be executed at a set 
frequency. By synchronizing the frequency of an event with the system clock it is 
possible to execute commands at a specific time. Timer acts as a counter and sends 
stored commands at the appropriate times to Glue. 

XML Events 

The main XML events that occur within the base system are: 

1. Setting up heartbeat URLs 

<docmd object- "Transmit' command* *SetURI#s" 

h eartbea c vrl =h t fcp ; //wtw. camms .com.au /a ubo t /c ol lecC or/heartbea t.asp 
dockurl = M http: / /www . camms . com . au/aubo t /col 1 ec t or /dock .asp" /> 

2. Registering the heartbeat frequency 



<docmd object= 'Timer* command* "Register" interval*'30' 
uni ts= " Seconds " > 
<data type- ■ Command " > 

<docmd object* 'Transmit* command* tt Heart Beat" /> 
</data> 

</docmd> 
3. Installation of new objects 

<docmd object*' Installer* command* "Ins tall' filename* 'object. dll»> 
<data type* - DLL *>' encoded DLL'</data> 
<data type*"SuccessCommand"> 

<docmd object* "Glue" command* "AddSystemDat a "> 
<docmd object- "Transmit" command* 'Dock 0 
da ta type- " Success " /> 
<data type* "Success "> 

<message writeout*" object.dll installed 
successfully. '/> 
</data> 
</docmd> 
</data> 

<da ta type* "Fai 1 ureCommand" > 

<docmd object* "Glue" command* "AddSystemDat a "> 
<docmd object* "Transmit* command* "Dock" 
da ta type* "Failure '/> 
<data type*" Failure" > 

<message writeout*" object.dll install failed. "/> 
</data> 
</docmd> 
<-/da ta> 
< /docmd> 



Establishing a heartbeat 

A heartbeat sent from the Transmit object informs that the Data Collector System is 
*alive\ The response from the central Data Collector System to a heartbeat is always 
to send a valid command, mostly a "do nothing" command. Figure 9 demonstrates the 
process of establishing a heartbeat. 

Installing a new object 

The installation process requires 3 main components: 
1. XML message containing installation instructions 
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2. 



Encoded DLL 



3. 



Success and failure commands 



Figure 10 demonstrates the installation of a new object by the Installer object 



5 FUNCTIONAL SYSTEM 



The Data Collector System functional system as depicted in Fig. 1 1 supports the 
following: 

1. Retrieval of data 

2. Storing of data 

10 3. Bundling of data . 
4. Transmission of data 

Functional System Objects 

The Data Collector functional system is comprised of the base system plus the 
following two objects: 
15 • Store 

• Connector 
Store 

Store is the object that manages the local database. It is necessary to collect 
information before sending it. Thus the information is temporarily stored in a 
20 database. Store includes functions to add items, bundle items, get a list of bundles, 
delete bundles, get a specific bundle and get the current bundle. This allows store to 
completely control the contents of the database. Store executes a command based on 
an accumulated size of data stored trigger or count trigger. This allows the user to 
configure how the database is to be managed. 

25 Connector 

The Connector object is used to connect to the remote data source. Connector has the 
capability of requesting a list of data items from the data source, registering groups of 
data items and reading those registered groups. The object has the capability of 
collecting events created by the data source. These events allow the Collector object 
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to register groups of alarms, thus when an alarm changes state, the Connector object is 
notified. 

XML Events 

The main XML events that occur within the functional system are: 
5 1. Connector gets data from data source 

<docmd object* * Connector 0 command* "Getlnfo* groupid* "accounts" /> 

2. Store adds data to local database 

<docmd object** Store" command* "Addltem* data type- " Trend" /> 

3. Store bundles data 

10 <docmd object** Store" command* "BundleCur rent I terns *> 

4. Store provides specific bundle 

<c?ocmd object* "Store" command* "GetBundle" bundleid="5* /> 

5. Store provides list of bundles 

<docmd object* "Store* command* "GetBundleList " /> 

15 6. Transmit sends bundle 

<docmd objects -Transmit' commands Dock" data type = "Bundle */> 

7. Transmit sends list of bundles 

<docmd object* "Transmit" command* "Dock" datatype* "BundleList */> 

8. Store deletes old bundles 

20 <docmd object** Store" command* * DeleteOldBundles * older than* "7" 

units* "Days" /> 

The events listed above occur whenever one of the following occurs: 
1 . When a set period of time has passed 

<docmd object* "Timer" command* "Register* interval* "30" units* "Minutes' 
25 swehtime* "00:00'> 

<data type* ' Command 

<docmd object* "Store" command= u GetB\indleLi3t u > 
<docmd object* "Transmit* command* 'Dock" 
datatype* "BundleList" 
30 </docmd> 
</data> 
</docmd> 

15 






2. 



When the local database contains a certain number of items or has reached a 



certain size 
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<docmd object* p Store" command* * SetTriggar3 0 itemscount^lOS" 
i temssizekbs- "800^^ 
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<data type- " Command "> 

<docmd object- "Store" command*- *BundleCurrentItems u > 
<docmd obj ect=' Glue" command="AddSystemData'' /> 
<docmd object*- 'Transmit" command- "Dock" datatype* "Bundle "> 

</docmd> 



</data> 



</docmd> 



3. 



When requested through Transmit 



15 Retrieving data at set time intervals 

The Timer object may be used to set the frequency at which specific groups of data 
are to be read and stored. 

Figure 12 demonstrates the retrieval of data from the remote data source and storage 
of this data into the local database. 

20 Sending data at set time intervals 

The Timer object may be used to set the frequency at which specific groups of data 
are to be sent. 

Figure 13 demonstrates the sending of data bundles at set time intervals. 

Sending data at set capacity levels 

25 The Store object may be used to set a capacity level at which specific groups of data 
are to be sent 

Figure 14 demonstrates the sending of data bundles at set capacity levels. 
Alternative Transmission Methods 

The Data Collector System utilizes the HTTP protocol for the transmission of data as 
30 it provides the following advantages: 
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1. The firewall remains open at all times allowing for the continual sending and 
receiving of information. 

2. Data can be passed in either direction. This enables the transmission of the 
remotely collected data, sending of Tm alj,ve" messages, retrieval of update 

5 commands and the passing back of status messages. 

3 . A connection can be either direct or made via a proxy server. 

4. An intermediate remote server is not required. 

5. The general user imperative for the HTTP protocol (Internet) to remain 
running at all times ensures that down time for communication between Data 

10 Collector System components is minimal. 

Despite these advantages, the Data Collector System may be modified to 
accommodate the following alternative protocols: 

• MSMQ 

• FTP 
15 • SMTP 



MSMQ 

MSMQ (Microsoft Message Queuing) is an effective way of communicating on LAN 
and WAN installations as it can be configured for guaranteed delivery. 

FTP 

20 FTP (File Transfer Protocol) enables the two-way transmission of files. 
SMTP 

SMTP (Simple Mail Transfer Protocol) enables the transmission of emails. 

It will be appreciated by those skilled in the art, that the invention is not restricted in 
25 its use to the particular application described. Neither is the present invention 

restricted in its preferred embodiment with regard to the particular elements and/or 
features described or depicted herein. It will be appreciated that various modifications 
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can be made without departing from the principles of the invention. Therefore, the 
invention should be understood to include all such modifications within its scope. 



Dated this 16 th day of April. 2002. 



CAMMS PTY LTD 

By their Patent Attorneys 

MADDERNS 
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Figure 2- Data Collector System Communication Environment 
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Figure 3 - Synchronous 



Figure 4 - Asynchronous 



Figure 5 Core system 
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Figure 6 Process of command execution 



1 Form at startup 

| Form | 



2 Form creates Glue 




3 Glue reads configuration file 




4 Glue instructed to create object X 



| Form f - 




5 Glue passes start command to object *X' for execution 
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Figure 7 Example of Glue executing and passing commands at startup 
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Figure 8 Base system 



Figure 9 establishing a heartbeat 



1 Timer receives instructions from Glue to send (hearbeat) command every 30 seconds 

<docmd 'objec t = " Timer * command* *R&gi s ter " interval ='30* 

uni C5=- "Seconds "> 

<rde ta type = "Coiwvand "> 

<docmd obj ecz=* Tran sini r " command* "Heart Beat" /> 

</data> 
</docmd> 




30 seconds passes 

2 Timer informs Glue that there is a command to execute. Glue adds command to queue to 
be eventually popped off as the current command 




3 Glue passes command to Transmit 

<docmd object* 'Transmit* command* "Hear fcBeafc " /> 



{ Form |- 




4 Transmit sends heartbeat 




5b Heartbeat returns with commands to execute 



<docmd oby 6ct- "Ins tal 1 ar * command* 'Install ' f.i I ename^ "object ,dll"> 
<data type* n DLL">' encoded DLl'</data> 
<data type- a SuccessConmand"> 

<docmd object* "Glue " command* "AddS'ystemDa ta "> 

<doavd object- 'Transmit* command- "Dock" data type* "Success" /> 
<da ra cyp e* M Su cc ess •> 

message wrlteout*"objcct.dll installed successfully . "/> 
</data> 
</docmd> 
</data> 

<da ta £>p©= -p a i 1 ureCoimand *> 

<6ocmd objects "Glue" command* "AddSystemData"> 

<doavd object* "Transmit* command* "Dock" datatype^Failure"/> 
<dava type* " Fax lure"> 

<message > wriceouv*" objecr.dll install failed. V> 
</data> 
</docmd> 
</data> 
</docmd> 




Figure 9 establishing a heartbeat 
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Figure 10 Installation of new object 

1 Transmit receives command and passes to Glue. Glue adds command to queue to 
be eventually popped off as the current command 
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2 Glue passes command to Installer 

<docmd object * "Instal ler 9 command* 'install " filename- "object.dll *> 
<data ty]?a=*DLL*>' encoded DLL'</dala> 
<da ta type= "SaccessComaand "> 

<docmd object- "Transmit 9 command- 9 Dock" datatype*" Success" /> 
<data types- * Success '> 

<message wri ceou r- "oojecv . dl 1 installed successfully . 9 /> 
</data> 

</daca> 

<da ta rype= "Fail ureCommand *> 

<docmd objects 9 Transmi t 9 coraraand= "Dock * data type- 9 Pai 1 iure •/> 
«iata type- "Failure 9 > 

<messacre writeout* 9 object.dll install failed. "/> 
</c/ata> 

</da~a> 




3 Installer attempts to install new object As Install was successful, Installer passes the 
command contained within the "SuccessCommand" datatype to the queue. The current 
command is passed back to Glue 
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Figure 10 Installation of new object 



4 Glue completes execution of the current command. Eventually the "success" command Is 
popped off as the current command and passed to Transmit 

<docivcl object= tt Transnii t • camvand^'Dock" datatype-.? 'Success* /> 
<daca type*" Success *> 

message wri reou r= ■ obj ec t.dll ins cai i ed successful J y . "/> 
</daca> 
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5 Transmit sends status and then passes the command back to Glue. As there are no more 
sub-commands, Glue ceases execution and pops the next command off of the queue 




Figure 10 Installation of new object 




Figure 11 Functional system 



{ # 

Figure 12 Retrieving data at set time intervals 

1 Timer receives instructions from Glue to send (Get-Add) command every minute 

<docmd object** Timer" coimnand*' Reg is ver" interval*'!" units* "Minutes 0 
synch time* "00 : 00 •> 
<da ca t>pe= * Command ' > 

<docmd object^* Connector* command* "Get Into"* 

<docicd object* "St ore" command* "Add! tern" datatype* "Info" /> 
</docmd> 
</data> 
</doavd> 





1 minute passes 

2 Timer informs Glue that there is a command to execute. Glue adds command to queue to 
be eventually popped off as the current command 




3 Glue passes "Getlnfo" command to Connector 



<dacvtd objec t.s " Connector " command- "Ge t Tnf o *> 

<docr,\d object "Store" command** Add! tern* datatype* 'Info* /> 
</docit\d> 




Connector retrieves data from remote data source and passes to Glue with current 
command. Glue checks if command contains sub-commands, and then promotes the first 
sub-command as the current command 




Figure 12 Retrieving data at set time intervals 
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5 Glue passes "Addltem" command to Store 

<6ocmCx object* 'Store* comutand^ n A6dltem u datatype-- "Info" /> 




6 Store adds data to local database and passes message back to Glue. As there are no more 
sub-commands, Glue ceases execution and pops the next command off of the queue 




Figure 12 Retrieving data at set time intervals 



Figure 13 Sending data at set time intervals 

1 Timer receives instructions from Glue to send a (Bundle-Dock) command every four hours 

<docmd object* "Timer M command- "Register* interval- "4" uni ts= "Honrs ' 
synchtimc= u 00 : 00 "> 

<data type- "Command *> 

<docmd object** Store* command- * Bund! eCurren 1 I terns *> 

<docmd object** Transmit" command- "Dock" datatype* "Bundle' /> 
</docmd> 
</data.> 
</docmd> 



Form 




I Configuration I 




4 hours pass 



• 



2 Timer Informs Glue that there Is a command to execute. Glue adds command to queue to 
be eventually popped off as the current command 




3 Glue passes "BundleCurrentltems" command to Store 

<docmd objec t:= «S tore " command* "Brmrll eCurren 1 1 1 ems "> 

<docv.d object* 'Transmit* ^;ci^iVnan.d=*Dock , • datatype^* Bundle* /> 
< /docmd> 




Figure 13 Sending data at set time intervals 
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4 Store bundles current items in the local database and passes bundle and current 
command back to Glue. Glue checks if command contains sub-commands, and then 
promotes the first sub-command as the current command 




5 Glue passes "Dock" command to Transmit 

<docmd object- 'Transmit* command^'Dock" datatype*" Bundle" /> 




Figure 13 Sending data at set time intervals 




7 Transmit returns bundle and commands to Glue. As there are no more 
sub-commands, Glue ceases execution and pops the next command off of the queue 



Figure 13 Sending data at set time intervals 
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Figure 14 the sending of data bundles at set capacity levels. 

1 Store receives instructions from Glue to send a (Bundle-Dock) command when local data 
base contains 200 data items 

<docmd object* •Store" conmaQV-'SetTriggers* itamscovnt* w 200* iten&slzekbs-'SOO^ 
<dava zype="Comoand"> 

<docmd object*" Store* coiwand=*BundleCui-rejitX terns "> 

<dcand object- 'Transai t • ccjoioarjd- *Dock * da ca type~ v Eundl e °> 
</docrod> 
</data> 
</docmd> 





Figure 14 the sending of data bundies at set capacity levels. 



A ^ ' 

4 Glue passes "BundleCurrentttems" command to Store 

< docmd obj ec t- "Store " command* "BuihSI eCu rren c 1 1 ems - > 

<dt?cmd objects ' Ti'ansmi t * command* "Dock " da ta type^ 'Buiidl e "> 
</docxd> 




5 Store bundles items In local database and passes back to Glue with command. Glue 
checks if command contains sub-commands, and then promotes the first sub-command 
as the current command 




Figure 14 the sending of data bundles at set capacity levels. 
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6 Glue passes "Dock" command to Transmit 

«SoamS object* transmit ■ comaan&'Dock* datatype* "Bundle's 




Transmit sends bundle and passes command back to Glue. As there are no more 
sub-commands, Glue ceases execution and pops the next command off of the queue 




Figure 14 the sending of data bundles at set capacity levels. 
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